//给你一个大小为 m x n 的二进制矩阵 grid 。 
//
// 岛屿 是由一些相邻的 1 (代表土地) 构成的组合，这里的「相邻」要求两个 1 必须在 水平或者竖直的四个方向上 相邻。你可以假设 grid 的四个边缘都
//被 0（代表水）包围着。 
//
// 岛屿的面积是岛上值为 1 的单元格的数目。 
//
// 计算并返回 grid 中最大的岛屿面积。如果没有岛屿，则返回面积为 0 。 
//
// 
//
// 示例 1： 
// 
// 
//输入：grid = [[0,0,1,0,0,0,0,1,0,0,0,0,0],[0,0,0,0,0,0,0,1,1,1,0,0,0],[0,1,1,0,1,
//0,0,0,0,0,0,0,0],[0,1,0,0,1,1,0,0,1,0,1,0,0],[0,1,0,0,1,1,0,0,1,1,1,0,0],[0,0,0,
//0,0,0,0,0,0,0,1,0,0],[0,0,0,0,0,0,0,1,1,1,0,0,0],[0,0,0,0,0,0,0,1,1,0,0,0,0]]
//输出：6
//解释：答案不应该是 11 ，因为岛屿只能包含水平或垂直这四个方向上的 1 。
// 
//
// 示例 2： 
//
// 
//输入：grid = [[0,0,0,0,0,0,0,0]]
//输出：0
// 
//
// 
//
// 提示： 
//
// 
// m == grid.length 
// n == grid[i].length 
// 1 <= m, n <= 50 
// grid[i][j] 为 0 或 1 
// 
//
// Related Topics 深度优先搜索 广度优先搜索 并查集 数组 矩阵 👍 990 👎 0


package LeetCode.editor.cn;

/**
 * @author ldltd
 * @date 2023-08-25 20:13:38
 * @description 695.岛屿的最大面积
 */
public class MaxAreaOfIsland{
	 public static void main(String[] args) {
	 	 //测试代码
	 	 Solution solution = new MaxAreaOfIsland().new Solution();

	 }
	 
//力扣代码
//leetcode submit region begin(Prohibit modification and deletion)
class Solution {

    public int maxAreaOfIsland(int[][] grid) {
		int res=0;
		for (int i = 0; i < grid.length; i++) {
			for (int j = 0; j < grid[0].length; j++) {
				if(grid[i][j]==1){
					res=Math.max(res,dfs(grid,i,j));
				}
			}
		}
		return res;
	}
	private int dfs(int[][] grid,int i,int j){
		if(i<0||i>=grid.length||j<0||j>=grid[0].length||grid[i][j]==0) return 0;
		else {
			grid[i][j]=0;
			return  1+ dfs(grid,i+1,j)
			+dfs(grid,i-1,j)
			+dfs(grid,i,j+1)
			+dfs(grid,i,j-1);
		}
	}

}
//leetcode submit region end(Prohibit modification and deletion)

}
